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(54) Title: TOOL GRINDING SIMULATION SYSTEM 
(57) Abstract 

A simulation system (20) for a CNC machine tool includes a 
swept surface calculation engine (21) for processing workpiece data 
and grinding wheel data representing information about the grinding 
wheel ( 1 2) and its programmed path to generate a set of geometric 
envelopes representing the solid volume occupied by the grinding 
wheel (12) as it moves along its programmed path. The envelopes, 
workpiece data and grinding wheel data are processed by a 3-D 
rendering engine (22) to produce a three-dimensional perspective 
image of the workpiece (1 1) as it would appear after being ground 
by the grinding wheel (12). The simulation system (20) also 
includes a manipulation and control interface (23) which may be 
used for a wide variety of purposes to enhance the three-dimensional 
image, such as position, orientation and zoom control, control of 
simulated illuminated light sources, control of texture maps and 
colour maps and overlay grids which may be superimposed on the 
surface of the simulated workpiece image. 
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TOOL GRINDING SIMULATION SYSTEM 
INTRODUCTION TO THE INVENTION 
This invention relates to computer numerically controlled (CNC) machine 
tools and in particular to computer generated visual simulation techniques for said 
5 machine tools. 

BACKGROUND OF THE INVENTION 

The development of multi-axis and multi-function machine tools in 
conjunction with the development of sophisticated computer controlled operation 
has facilitated the emergence of a generation of very high speed precision machine 
10 tools capable of complex multi-step operations from one machine. 

Typically a CNC machine is controlled by a computer program, called a 
"part program", which serially instructs the machine to perform a sequential series 
of discrete operations in a predetermined sequence so that a movable operative part 
of the machine tool, such as a milling cutter or grinding wheel, moves along a 
15 programmed path determined by the part program. Each individual instruction is 
termed a "block" and may constitute a determining command for each or a 
combination of controllable axes. For example, a block may instruct a grinding 
wheel to move 5 mm in the Y axis at a given velocity or instruct a grinding wheel 
to rotate and move forward 0.05 mm in the X and Y axes at a given velocity. The 
20 blocks, once programmed into the computer, are then fixed in a set sequential order. 
The whole set of sequential blocks may then be automatically operated by the CNC 
machine which then operates from start to finish of the part program. 

It is desirable when testing a part program for a complex machine tool to 
provide a visual simulation of the motion of the operative part of the machine tool 
25 and the machining process prior to physically operating the motion of the operative 
part. This simulation can be performed off-line using suitably configured three- 
dimensional graphics simulation systems but therein relies on separate computing 
equipment to that provided by the CNC of the machine tool and corresponding 
complexity in transferring part programs and simulation data between the CNC and 
30 the simulation computer. 

For one particular class of machines, the tool and cutter grinder, it is 
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particularly useful to provide graphical simulation of the machining process. A 
CNC tool and cutter grinder typically has at least four continuous path axes and is 
used to manufacture or resharpen spiral fluted cutting tools (the workpiece) such 
as end-mills, rotary files, drills, reamers and the like. Hereinafter the terms 
5 workpiece and cutting tool are used interchangeably. The surface features that are 
produced on these workpieces are usually generated by complex sweeping motions 
of the grinding wheel(s) whereby the resultant surface is more geometrically 
complex than the surface of the grinding wheel. It is therefore difficult to ensure 
that the desired workpiece shape is produced from the parameters entered into the 
10 part program that defines the motions of the grinding wheel of the tool and cutter 
grinder without the use of three dimensional graphics simulation. Traditional three 
dimensional simulation tools are not capable of processing the complex data 
produced by a multi-axis CNC controlled tool and cutter grinder. 

It is therefore desirable to provide a computerised simulation environment 
15 for tool and cutter grinding machines which provides automated, computerised tools 
that are based on work practices that are used in manual simulation and verification 
procedures. 

It is also desirable to provide a CNC for complex multi-axis machine tools 
which can provide three-dimensional, shaded colour graphics simulation of the 
20 machining process without the need for an additional simulation computing system. 

It is further desirable to provide a calculation system that provides complete 
mathematical surface descriptions for the purpose of more accurate machine tool 
path generation in complex multi-axis machine tools. 
SUMMARY OF THE INVENTION 
25 According to one aspect of the invention there is provided a simulation 

system for a computer numerically controlled (CNC) machine tool having a 
movable operative part for operating on a workpiece; 

said CNC machine tool being programmed with a part program which 
instructs the machine to perform a sequential series of discrete operations in a 
30 predetermined sequence to control movement of the operative part along a 
programmed path determined by the part program; 
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said CNC machine tool including a machine tool programming system to 
generate data representing information about the operative part, the workpiece and 
the programmed path; 

wherein the simulation system includes: 
5 processing means for processing the data generated by the machine tool 

programming system to produce a three-dimensional image of the workpiece as it 
would appear after operation of the operative part on the workpiece in accordance 
with the part program; 

a visual display unit (VDU) for displaying the three dimensional image; and 
10 manipulation and control means for manipulating and controlling the 

appearance of the three-dimensional image on the visual display unit. 

Preferably, the processing means is also arranged to produce a three- 
dimensional image of the operative part for display on the visual display unit. The 
processing means is preferably arranged to generate perspective views of the 
15 workpiece and/or operative part from different viewing directions, and the display 
of said perspective views is controlled by the manipulation and control means. 

The operative part of the machine tool may comprise any type of 
CNC cutting or grinding tool. In one preferred embodiment of the invention, the 
operative part comprises a grinding wheel. 
20 The machine tool may be programmed to manufacture a workpiece (e.g. a 

cutting tool) from a blank workpiece. Alternatively, the machine tool may be 
programmed to sharpen the edges of an existing workpiece (e.g. a cutting tool). 
The method of the present invention is particularly applicable to CNC machines in 
which a grinding wheel as the operative part is programmed to move with at least 
25 four degrees of freedom relative to a workpiece to manufacture or sharpen a spiral 
fluted cutting tool (the workpiece). Examples of spiral fluted cutting tools which 
may be manufactured or sharpened by a CNC machine incorporating the invention 
include: end-mills; rotary files; drills; reamers and the like. 

The simulation system is preferably incorporated within the CNC machine 
30 to form part of the CNC machine. Alternatively, the simulation system may 
comprise a computer system separate from, but in communication with, the machine 
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tool programming system. 

Preferably, the processing means is arranged to generate envelope data 
representing the outer limits of motion of the operative part of the machine tool. 
The simulation system preferably includes swept surface calculation means 
5 programmed to calculate surface data for the workpiece image. The surface data 
may correspond to the position and surface properties of a surface of the workpiece 
as it would appear after being operated upon or "swept" by the operative part. 

Preferably, the simulation system includes a three dimensional image 
rendering engine arranged to produce a three dimensional rendered image of the 
10 workpiece and, optionally, of the operative part which can then be displayed on a 
visual display unit (VDU) of the simulation system. 

The simulation system may include overlay means for generating a scaled 
grid overlay controlled by the manipulation and control means for display on the 
VDU simultaneously with the three-dimensional image. This is advantageous in 
15 that it enables measurements of the workpiece image to be made. 

The scaled grid overlay preferably comprises concentric circles and radial 
lines originating from the center of the circles and said concentric circles are 
marked with a scale' to indicate the radius of each circle as it applies to the scale 
of the three dimensional image of the workpiece. 
20 The manipulation and control means may also manipulate and control 

other features of the image displayed on the VDU. The manipulation and control 
means may be used for a variety of purposes, including the manipulation and 
control of: the relative size and position of the image on the VDU; simulated light 
sources for illumination of the image of the workpiece or cutting tool; and/or the 
25 appearance of the image. 

The simulation system may be used to simulate a machining process of the 
CNC machine. This is preferably achieved by the system being programmed or 
controlled to generate animated sequences of images which depict the machining 
process at successive time intervals by producing three dimensional images of the 
30 machined workpiece as it would appear at time intervals during the actual 
machining process. Accordingly, the manipulation and control means may be used 

SUB S ill U lb SHEET (Rule 26) 



1NSDOCID: <WO_ 9809203A1J_> 



WO 98/09203 




PCT/AU97/00565 
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to control the simulation system to display continuous machining operations, 
individual machining operations, or the completed workpiece only. 

The simulation system may include map generating means for generating and 
displaying a texture map and/or colour map of the surface of the operative part of 
5 the machine tool or of the workpiece which map can be superimposed onto the 
three dimensional rendered image of the operative part or simulated workpiece. 

A texture map may consist of fine lines, the density and direction of which 
may simulate surface scratches which would be produced as a result of the cutting 
action of the operative part scratching the surface of the workpiece during the 
10 machining process. 

Alternatively, a colour map may consist of a graduated, colour coded image 
of the workpiece and/or of the operative part. The simulation system may be 
arranged to display a colour coded view of the operative part and workpiece 
wherein the colour of each region of the surface of the workpiece represents a 
15 similarly colour coded region of the operative part that would grind the region of 
the workpiece during the machining process. Alternatively, the simulation system 
may be arranged to display a colour coded image of the workpiece wherein the 
colour of each region of the surface of the workpiece represents the scale of the 
volume of material to be removed per unit of time when the operative part is in 
20 contact with the region during the machining process. 

A texture map may also consist of one or more curved lines superimposed 
on the three-dimensional image of the workpiece. The lines may represent 
instantaneous lines of contact between the machine tool and the workpiece surface 
at specific times of the machining process. Alternatively, or additionally curved 
25 lines may represent lines of constant contact between specific regions of the 
operative part arid the machined surface of the workpiece over the continuum of 
intervals of the machining process. 

Whilst the simulation system of the present invention may be incorporated 
with or used in conjunction with any type of CNC machine having an operative part 
30 operable on a workpiece, it is particularly applicable to a CNC machine in which 
the operative part is a grinding wheel used to machine or grind a workpiece which, 
« 
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in its machined form, itself comprises a cutting tool such as a rotary file, drill bit 
or other spiral fluted cutting tool. 

In a particularly preferred embodiment, a CNC machine is programmed to 
generate envelope data describing the outer limits of motion of a grinding wheel or 

5 other operative part moving with at least four degrees of freedom relative to a 
workpiece. The envelope data may be processed to produce surface data describing 
the position and surface properties for the complete swept surface of the workpiece 
(e.g. a flute of a cutting tool). The surface data may be transferred to a path 
controller of the CNC machine for adjusting the machining path of the operative 

10 part of the machine tool. This enables features of the workpiece (e.g. flutes of a 
cutting tool) to be machined more accurately during the machining process of the 
CNC machine. 

BRIEF DESCRIPTION OF THE DRAWINGS 

A preferred embodiment of the present invention will now be described, by 
15 way of example only, with reference to the accompanying drawings, in which: 

Figure 1 is a block diagram of a CNC machine incorporating a simulation 
system in accordance with the invention; and 

Figure 2 is a more detailed block diagram of a three dimensional rendering 

engine of the system of Figure 1; 
20 Figure 3 is a schematic diagram of a manipulation and control interface of 

the system of Figure 1; 

Figure 4 is a view of a display screen with a scaled grid overlay; 
Figure 5 is another view of a display screen with a scaled grid overlay and 
including an angular measurement tool; 
25 Figure 6 is a further view of a display screen with a pointing device; 

Figure 7 is yet another view of a display screen with a data display for 

measurements; and 

Figure 8 is a still further view of a display screen including a texture map 
formed from a grind of curved lines superimposed on the three-dimensioned image 
30 of the workpiece. 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 
In a preferred embodiment of the invention a CNC machine tool 1 for 
machining a workpiece 10 includes a workpiece holder 11, a grinding wheel 12 for 
operating on the workpiece 10 in a machining operation, a tool grinding 
5 programming system 13 programmed to generate part program data 14 which 
serially instructs the machine to perform a series of discrete operations in a 
predetermined sequence, a keyboard 15 for entering instructions into the 
programming system 13, a path controller 16 which receives the part program data 
14 and a servo system 17 which controls movement of movable parts of the 
10 machine under instructions from the path controller 16 to move the machine tool 
12 along a programmed path determined by the part program. The CNC machine 
also includes a simulation system 20 which is arranged to produce simulated 
images of the workpiece 10 and/or the grinding wheel 12 on display means in the 
form of a visual display unit (VDU)18. The simulation system 20 is programmed 
15 to intercept part program data 14, workpiece data and wheel description data prior 
to activation within the path controller 16 of the CNC. This intercepted data is 
channeled to the simulation system 20 which may be resident within the CNC. The 
simulation system/ 20 comprises a swept surface calculation engine 21 a three 
dimensional (3D) rendering engine 22, a manipulation and control interface 23 and 
20 a selectable projector or measurement overlay 24. 

The simulation system 20 of the CNC intercepts from the programming 
system 13 machine tool data or "wheel data", which describes the shape of the 
grinding wheel, workpiece data or "blank data" which describes the shape of the 
blank (workpiece prior to machining), and data describing the desired parameters 
25 of the finished workpiece. It also intercepts part program data 14 representing the 
programmed or calculated path of the grinding wheel 12 which will be used to 
grind the workpiece 10. This data is passed to the swept surface calculation engine 
21 within the simulation system. 

Within the swept surface calculation engine 21, the geometric envelope of 
30 the grinding wheel 12 as it is simulated to move through each defined move is 
calculated. The geometric envelope is defined as the outer surface (or skin) of the 

* 
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volume that is swept by the moving grinding wheel 12. In other words, any blank 
material that is inside this envelope would be removed during the grinding process 
and all material that is outside this envelope would be left untouched by the 
grinding process. The set of the envelopes for all grinding wheel moves defined 
5 within a grinding process for a single workpiece defines the complete volume that 
the grinding wheel 12 will sweep during the complete grinding process. 

The data for the set of geometric envelopes is transferred to the 3D rendering 
engine 22 along with data for the shape of the blank and data for the grinding 
wheel. Within the rendering engine 22 (see figure 2), a tessellation module 25 
10 performs a tessellation operation on the set of envelopes, the grinding wheel data 
and blank data to produce display lists comprising polygons which represent the 
surfaces of the envelopes, blank and grinding wheel. These display lists are then 
processed by a Constructive Solid Geometry (CSG) module 30 which performs a 
boolean subtraction 32 and rasterisation 34 of the set of envelopes from the blank 
15 to produce a rendered image of the complete surface of the completely simulated 
workpiece 10 and a rendered image of the grinding wheel 12. 

The simulation system 20 can be activated in such a way as to return surface 
data from the swer/t surface calculation engine 21 to the path controller 16. In this 
mode of operation, part program data 14 is also passed to the path controller 16 as 
20 well as to the simulation system 20. The surface data is used by the path controller 
16 to align machining paths accurately with the generated surfaces. 

The three dimensional rendering is performed using three dimensional 
graphics acceleration facilities of the display hardware and software to produce a 
smooth shaded, lighted, colour three dimensional image of the completely simulated 
25 workpiece on the Visual Display Unit (VDU) 18. 

The Manipulation and Control Interface (MCI) 23 is provided for the 
machine tool operator to manipulate the appearance of the simulated workpiece on 
the VDU 18. The MCI 23 provides display mode controls 26 for adjusting the 
sequence in which the simulation is drawn on the VDU 18. This sequence is 
30 controlled by the following modes: 
Full grinding mode; 
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Full operations mode; and 
Operation in progress mode. 



In Full grinding mode, the image of the simulated workpiece is drawn in its 
completed (machined) state. In Full operations mode, the image of the workpiece 
5 is successively drawn in sequential stages of its simulated grinding process. After 
each grinding operation (e.g. flute grinding of flute #1, Backoff grinding of flute #4 
etc) the image is redrawn showing the workpiece as it would appear at the 
completion of the actual grinding operation. Using this mode, the operator can see 
the sequence in which material is removed from the blank during the grinding 
10 process to produce the completed workpiece. 

In Operation in progress mode, the image is continuously redrawn to show 
in fine detail, the sequence in which material would be removed from the blank 
during the grinding process. This mode provides the operator with the most 
realistic visual feedback of the simulated grinding process. 
15 The MCI 23 may provide other controls for manipulating the operator's view 

of the simulated workpiece. These controls include a position control 41 for 
controlling the position of the image on the display screen, a zoom control 42 for 
zooming of the image, orientation controls 43 for panning and rotation of the 
image, and an illumination control 44 for moving the location and intensity of 
20 simulated light sources. 

The swept surface calculation engine 21 may also calculate surface texture 
and colour maps from the wheel data, blank data and grinding path data passed to 
it. The MCI 23 is provided with a texture map control 45 and a colour map control 
46 for enabling each of the texture and colour maps to be superimposed on the 
25 simulation image. The maps may include any one or more of the following: 
Surface finish texture map; 
Wheel map; 
Contact lines map; and 
Metal removal rate map. 
30 A surface finish texture map describes the relative surface finish expected 
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at each point on the surface of the completed workpiece. This information is 
automatically calculated within the swept surface calculation engine 21 by 
considering the direction of motion of the grinding wheel 12 at each point on each 
envelope relative to the surface normal to the envelope at each point. The surface 
5 finish texture map may comprise fine lines superimposed on the surface of the 
simulated workpiece depicting the density of surface defects and the directional 
alignment of the defects where the defects are a natural surface feature of the 
grinding process and are produced by the scratching action of the grinding wheel 
grains over the surface of the workpiece as material is removed from the workpiece 
10 during the grinding process. 

A wheel map is a graduated, colour coded map which is superimposed onto 
the surface of the simulated workpiece. Each colour represents a particular region 
of the grinding wheel. The mapping of this colour map onto the surface of the 
simulated workpiece indicates the region of the grinding wheel which will perform 
15 the actual grinding operation for each region of the ground surfaces of the 
completed workpiece. This information is automatically calculated within the swept 
surface calculation engine 21 by considering the line of contact between the 
grinding wheel and the workpiece at each point on the ground surface of the 
workpiece. The machine tool operator can use this map to predict regions of the 
20 grinding wheel that will be subjected to abnormally high heat distributions or wear 
characteristics due to uneven distribution of grinding loads over the surface of the 
grinding wheel. 

Figure 8 shows an example of a contact lines map consisting of a grid of 
curved lines. The lines 51 in one direction represent instantaneous lines of contact 

25 between the grinding wheel and the geometric envelope of the workpiece for 
successive time sequences during simulated grinding. The lines 52 in the other 
direction represent lines of contact of specific regions of the grinding wheel over 
time. This information is automatically calculated within the swept surface 
calculation engine 21. The machine tool operator can use this map to determine, 

30 for any time interval of the grinding sequence, what region of the geometric 
envelope will be generated by the motion of a particular portion of the grinding 
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wheel. 

A metal removal rate map is a graduated, colour coded map which is 
superimposed onto the surface of the simulated workpiece. Each colour represents 
a value for the volume of material that will be removed from the blank per unit of 
5 time. The mapping of this graduated colour scale onto the surface of the cutting 
tool image represents the distribution of volumetric metal removal rates over the 
surface of the cutting tool. 

The MCI 23 of the simulation system 20 may provide a further control for 
the projector overlay 24 which when enabled, generates a scaled measurement grid 
10 which can be overlaid or superimposed on the image 50 of the simulated workpiece 
on the VDU of the CNC. The scaled grid provides immediate visual feedback to 
the operator of certain dimensional characteristics of the workpiece. A further MCI 
grid control 47 enables the user to select between available grid patterns. Available 
grid patters include pre-defined grids and user defined grids. The invention 
15 provides for the following pre-defined grids: 

Radius/Diameter/Length measurement; 

Angle measurement; and 

Flute shapes. 

The Radius/Diameter/Length measurement grid 60 as shown in Figures 4 and 
20 5 is a pattern that is designed to be as similar as possible to the grids used on 
standard manual light projector equipment typically used for measurement 
verification of cutting tool geometry. It includes a pattern of concentric circles 61 
and radial lines 62 originating from the centre of the circles 62 with radius and/or 
diameter markings 63 in imperial or metric units. The operator uses the position, 
25 zoom and orientation controls 41, 42, 43 to position the grid over the top of the 
feature of interest on the image 50 of the simulated workpiece and then uses the 
markings 63 on the grid 60 to determine the dimensions of the feature of interest. 

Preferably, the grid 60 is automatically adjusted during zooming control of 
the three-dimensional image of the workpiece so that the scale of the grid remains 
30 constant with respect to the scale of the workpiece image as it appears on the VDU. 
The density of the concentric circles 61 may be automatically adjusted so that the 
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density of the circles lies within a predetermined range. Further, the grid control 
47 may include a selection means to adjust the range of allowable values of 
concentric circle density. 

The grid control 47 may also allow the radial lines 62 of the measurement 
5 grid to be rotated about the centre of the concentric circles as shown in Figure 5, 
with the VDU 18 including angular position display means 64 for displaying the 
angle of rotation of the grid 60 from a default angular position as shown in Figure 
4 in which the radial lines extend vertically and horizontally on the VDU 18. 

The grid control 47 may include zeroing control means 74 for causing the 
10 angular position display 64 to read zero, with subsequent angles displayed on the 
angular position display being angles of the grid relative to the angular position of 
the grid when the zeroing control was selected. 

The Angle measurement grid provides graduated radial lines marked in 
degrees. The operator uses this grid to measure angular features on the image of 
15 the simulated workpiece. The flute shapes grids provide a set of popular cross- 
sectional shapes for the flutes of cutting tools. These grids can be used by the 
operator to determine how well the simulated workpiece conforms to the original 
design specifications for the workpiece. Thus, they provide a means for accurately 
verifying the grinding process prior to performing the grinding operation. 
20 User defined grids can be any grid pattern or scaled two dimensional 

drawing which can be drawn with a Computer Aided Design (CAD) package and 
loaded into the CNC as a data file. 

The measurement and control interface (MCI) 23 may also include a pointing 
device control 48 for selecting one or more points 65, 75 on the surface of the 
25 three-dimensional image 50 of the workpiece and measurement means 49 for 
interrogating the selected points. The VDU may include a measurement display 66 
as shown in Figure 7 for displaying the co-ordinates 68 of a selected point 65 
representing the location of the selected point 65 on the surface of the simulated 
workpiece 50. The measurement display 66 may also display data representing the 
30 orientation of the surface of the simulated workpiece 50 at the selected point 65. 
The VDU may also include an orientation display 67 for displaying the orientation 
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of the surface at the selected surface point as at least one of two components, the 
first component representing the angle that the surface makes with respect to the 
radial axis of a cylindrical coordinate system represented by the axes (r,0,l) 
embedded in the workpiece wherein said angle is measured in the plane of constant 
5 (1) in said cylindrical coordinate system and said radial axis is aligned (in 6) such 
that said radial axis points toward the selected surface point and the second 
component representing the angle that the surface makes with respect to said radial 
axis, measured in the plane of constant 0 in said cylindrical coordinate system 
whereby 9 is aligned such that said radial axis points toward the selected surface 
10 point. 

When a second point 75 is selected by the pointing device control 48, the 
measurement display 66 may include a "Delta" display for displaying the distance 
between the first and second selected points as a distance value 59 and/or as the 
difference in co-ordinates 70 between the two points in the same scale and units 

15 as the dimensions of the workpiece. 

A new surface orientation may be substituted for the actual workpiece 
surface orientation at the first selected point for use in the calculation and display 
of surface orientations, the workpiece surface being transformed into said new 
surface by rotation about a direction which is perpendicular to both the line 

20 connecting the first and second selected points and the surface normal of the 
workpiece surface at the first selected point, the rotation being sufficient such that 
the surface tangent of the new surface aligns with the direction of the line between 
the first selected point and the second selected point. 

The MCI 23 may provide a further control, whereby the swept surface 

25 calculating engine 21 is controlled to produce mathematical data to describe the 
geometric envelopes (Surface Data in Figure 1). In this mode, the path controller 
can use this data to ensure that generated machine tool paths align perfectly with 
the swept surface to machine the desired surface features accurately. In tool and 
other cutter grinding, this feature is particularly useful. Traditionally, the complete 

30 mathematical data for the swept surface of the flute of a cutting tool is not known. 
Using the invention, this data can be precisely calculated. When other features of 
« 
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the tool are ground deeply into this swept surface, the accurate positioning of the 
feature with respect to the swept surface can only be assured if the position of the 
swept surface is accurately known at all points on the surface. Prior to using this 
mode of the invention, offset values would normally be entered into the CNC by 
5 the operator to adjust for positional errors caused by this lack of data. 

The advantages of the invention over traditional techniques of simulation for 

tool and cutter grinding include: 

complete workpiece may be visualised in three dimensions with accurate 

representation of all surface features; 
10 changes made to the grinding process at the machine operator's console can 

be immediately simulated and verified; and 

program verification can be performed on simulated models of the 
workpiece, using tools that are familiar to users of manual verification procedures; 
and 

15 optionally, simulation can be performed at the machine tool without the use 

of a separate simulation computer by using the services of the CNCs computer(s); 
Workpiece features which intersect swept surfaces can be accurately located. 



It will be appreciated that various modifications and alterations may be made 
to the preferred embodiment without departing from the spirit and scope of the 
20 present invention. For instance, a simulation system may be provided in accordance 
with the invention which is separate from but able to communicate with, a CNC 
machine to extract data from the CNC machine to produce rendered images of the 
workpiece and/or machine tool for display on a VDU of the simulation system. 
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CLAIMS 

1. A tool grinding simulation system for a computer numerically controlled 
(CNC) machine tool having a movable operative part for operating on a workpiece; 

said CNC machine tool being programmed with a part program which 
5 instructs the machine to perform a sequential series of discrete operations in a 
predetermined sequence to control movement of the operative part along a 
programmed path determined by the part program; 

said CNC machine tool including a machine tool programming system to 
generate data representing information about the operative part, the workpiece and 
10 the programmed path; 

wherein the simulation system includes: 

processing means for processing the data generated by the machine tool 
programming system to produce a three-dimensional image of the workpiece as it 
would appear after operation of the operative part on the workpiece in accordance 
15 with the part program; 

a visual display unit (VDU) for displaying the three dimensional image; and 
manipulatidn and control means for manipulating and controlling the 
appearance of the three-dimensional image on the visual display unit. 

2. A simulation system according to claim 1 wherein the processing means is 
20 also arranged to produce a three-dimensional image of the operative part for 

display on the visual display unit. 

3. A simulation system according to claim 1 or claim 2 wherein the processing 
means is arranged to generate perspective views of the workpiece and/or operative 
part from different viewing directions, and the display of said perspective views is 

25 controlled by the manipulation and control means. 

4. A simulation system according to any one of claims 1 to 3 further including 
overlay means for generating a scaled grid overlay, the manipulation and control 

« 
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means controlling the display of the scaled grid overlay on the visual display unit 
simultaneously with the three-dimensional image of the workpiece and/or operative 
part. 

5. A simulation system according to claim 4 wherein the scaled grid overlay 
5 comprises concentric circles and radial lines originating from the center of the 

circles and said concentric circles are marked with a scale to indicate the radius of 
each circle as it applies to the scale of the three dimensional image of the 
workpiece. 

6. A simulation system according to claim 5 wherein the scaled grid overlay 
10 is automatically adjusted during zooming control of the three-dimensional image 

of the workpiece such that the scale of the grid remains constant with respect to the 
scale of the workpiece image as it appears on the VDU. 

7. A simulation system according to claim 6 wherein the density of concentric 
circles on the VDU is automatically adjusted such that the density of circles lies 

15 within a predefined range. 

8. A simulation system according to claim 7 wherein a selection means is 
provided to adjust the allowable range of the value of concentric circle density. 

9. A simulation system according to any one of claims 5 to 8 wherein an 
angular measurement control means is provided, said means allowing the radial grid 

20 lines to be rotated about the center of the concentric circles grid and the angle of 
rotation of the grid from the default angular position is displayed on the VDU. 

10. A simulation system according to claim 9 wherein an angular measurement 
zeroing control means is provided, whereby selection of such means causes the 
angular position display to read 0.0 and thereafter, angles displayed on the angular 
25 position display are angles of the grid relative to the angular position of the grid 
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when this zeroing control was selected. 

11. A simulation system according to any one of claims 1 to 3 further including 
measurement means for interrogating points on the surface of the workpiece, 
whereby the measurement means is controlled by pointing device means and data 

5 is displayed on the VDU relating to the point on the surface of the workpiece which 
has been selected by pointing means. 

12. A simulation system according to claim 11 wherein data displayed on the 
VDU includes the coordinates of the point being interrogated where such 
coordinates represent the location of the selected point on the surface of the 

10 workpiece, 

13. A simulation system according to claim 12 wherein data displayed on the 
VDU includes the orientation of the surface of the workpiece at the selected surface 
point. 

14. A simulation system according to claim 13 wherein the orientation of the 
15 surface at the selected surface point is displayed as at least one of two components, 

the first component representing the angle that the surface makes with respect to 
the radial axis of a cylindrical coordinate system represented by the axes (r,0,l) 
embedded in the workpiece wherein said angle is measured in the plane of constant 
(1) in said cylindrical coordinate system and said radial axis is aligned (in 6) such 
20 that said radial axis points toward the selected surface point and the second 
component representing the angle that the surface makes with respect to said radial 
axis, measured in the plane of constant 0 in said cylindrical coordinate system 
whereby 6 is aligned such that said radial axis points toward the selected surface 
point. 

25 15. A simulation system according to any of claims 11 to 14 whereby a second 
point may be selected on the surface of the workpiece. 
♦ 

SUBSTITUTE SHEET (Rule 26) 

BNSDOCtD: <WO 9609203A1..I, > 



WO 98/09203 ~ " PCT/AU97/00565 

18 

16. A simulation system according to claim 15 wherein the distance between the 
first and second selected points is displayed on the VDU as the distance between 
the two points and/or the difference in coordinates between the two points in the 
same scale and units as the dimensions of the workpiece. 

5 17. A simulation system according to claim 15 as appended to claim 13 or claim 
14 wherein a new surface orientation is substituted for the actual workpiece surface 
orientation at the first selected point for use in the calculation and display of surface 
orientations and the workpiece surface is transformed into said new surface by 
rotation about a direction which is perpendicular to both the line connecting the first 
10 and second selected points and the surface normal of the workpiece surface at the 
first selected point, said rotation being sufficient such that the surface tangent of the 
new surface aligns with the direction of the line between the first selected point and 
the second selected point. 

18. A simulation system according to any one of the preceding claims further 
15 including texture and/or colour map generating means for generating a texture map 
and/or colour map' of the surface of the workpiece and/or operative part, the 
manipulation and control means controlling the display of the texture map and/or 
colour map on the visual display unit, and the texture or colour map is applied to 
the surface of the three-dimensional image of the workpiece and/or operative part. 

20 

19. A simulation system according to claim 1 8 wherein the texture and/or colour 
map comprises a graduated, colour coded image of the workpiece and/or operative 
part. 

20. A simulation system according to claim 19 wherein the system is controlled 
25 to display colour coded views of the workpiece and operative part in which the 

colour of each region of the surface of the workpiece corresponds to a similar 
colour coded region of the operative part that would operate on the region of the 
workpiece during the machining process. 

SUBSTITUTE SHEET (Rule 26) 



JNSDOdlD; <WO 9809203 A 1_1_> 



WO 98/09203 




PCT/AU97/00565 



19 



21. A simulation system according to claim 19 wherein the system is controlled 
to display a colour coded image of the workpiece in which the colour of each 
region of the surface of the workpiece represents the volume of material to be 
removed per unit of time when the operative part is in contact with the workpiece 

5 during the machining process. 

22. A simulation system according to claim 18 wherein the texture map 
comprises a series of fine lines superimposed on the three dimensional image of the 
workpiece to simulate surface scratches which would be produced as a result of 
the cutting action of the operative part scratching the surface of the workpiece 

10 during the machining process. 

23. A simulation system according to claim 18, wherein the texture map 
comprises one or more curved lines superimposed on the three-dimensional image 
of the workpiece, each line representing the instantaneous line of contact between 
the operative part and the machined surface of the workpiece at a specific time of 

the machining process. 

/ 

/ 

24. A simulation system according to claim 18, wherein the texture map 
comprises one or more curved lines superimposed on the three-dimensional image 
of the workpiece, each line representing a line of contact between a specific region 
of the operative part and the machined surface of the workpiece over the continuum 
of the time intervals of the machining process. 

25. A simulation system according to claim 18, wherein the texture map 
comprises a grid of two or more curved lines superimposed on the three- 
dimensional image of the workpiece, wherein each line in one direction represents 
the instantaneous line of contact between the operative part and the machined 

25 surface of the workpiece at a specific time of the machining process and each line 
in the other direction represents a line of contact between a specific region of the 
operative part and the machined surface of the workpiece over the continuum of 
« 
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time intervals of the machining process. 



26. A simulation system according to any one of the preceding claims including 
simulated illumination means for simulated illumination of the three-dimensional 
images of the workpiece and/or operative part, the simulated illumination means 

5 being controlled by the manipulation and control means. 

27. A simulation system according to any one of the preceding claims wherein 
the processing means is arranged to generate animated sequences of three- 
dimensional images of the workpiece as it would appear at successive time intervals 
during the machining process. 

10 28. A simulation system according to claim 27 wherein the manipulation and 
control means allows for selection of any one of the following simulated display 
modes: continuous machining operations; individual machining operations; and 
completed workpiece display. 

29. A simulation system according to any one of the preceding claims wherein 
15 the processing means is arranged to process data representing information about the 

operative part and its programmed path to generate envelope data representing the 
solid volume occupied by the operative part as it moves along its programmed path 
relative to the workpiece. 

30. A simulation system according to claim 29 including calculation means for 
20 processing the envelope data and workpiece data representing the information about 

the workpiece to calculate swept surface data describing the position and surface 
properties of the surface of the workpiece as it would appear after being operated 
upon by the operative part. 

31. A simulation system according to claim 29 or claim 30 including a three- 
25 dimensional rendering engine for processing operative part data representing the 

SUBSTITUTE SHEET (Rule 26) 



1NSDOCID: <WO 9809203A1J_> 



WO 98/09203 




PCT/AU97/00565 



21 

shape of the operative part, the envelope data and the workpiece data to produce 
three-dimensional rendered images of the workpiece and operative part. 

32. A simulation system according to claim 31 wherein the three-dimensional 
rendering engine includes a tessellation module for performing tessellation 

5 operations on the operative part data, the envelope data and the workpiece data to 
produce display lists in the form of polygons representing the surfaces of solid 
volume of the operative part and the workpiece. 

33. A simulation system according to claim 17 wherein the three-dimensional 
rendering engine includes a Boolean subtraction engine for subtracting the solid 

10 volume of the envelopes and the solid volume of the operative part from the solid 
volume of the workpiece to produce the three-dimensional rendered image of the 
workpiece as it would appear after being operated upon by the operative part, 

34. A CNC machine tool including a simulation system in accordance with claim 
30 and a path controller for controlling movement of the operative part relative to 

15 the workpiece, wherein the swept surface data is transferred to the path controller 
for adjusting the path of the operative part. 
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